All files / web/src/app/api/song-shares/[code] route.ts

0% Statements 0/28
0% Branches 0/1
0% Functions 0/1
0% Lines 0/28

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29                                                         
/**
 * Public read for a shared celebration song.
 *
 * GET /api/song-shares/[code]
 *
 * No auth (guest-allowed in enforcer.ts). The share `code` is the only
 * credential. Delegates to `getSharedSong` for the server-side projection
 * (the privacy boundary). Does NOT bump the view counter — the public page
 * render is the canonical view surface and owns that increment.
 */

import { NextResponse } from 'next/server'
import { withAuth } from '@/lib/auth/withAuth'
import { getSharedSong } from '@/lib/song-share/getSharedSong'

export const GET = withAuth(async (_request, { params }) => {
  try {
    const { code } = (await params) as { code: string }
    const payload = await getSharedSong(code)
    if (!payload) {
      return NextResponse.json({ error: 'Not found' }, { status: 404 })
    }
    return NextResponse.json(payload)
  } catch (err) {
    console.error('Error reading song share:', err)
    return NextResponse.json({ error: 'Failed to load song' }, { status: 500 })
  }
})